草庐IT

C++11 auto 和 size_type

全部标签

c++ - utf-8 中 std::string 的子字符串? C++11

我需要获取假定为utf8的std::string中前N个字符的子字符串。我了解到.substr无法正常工作……正如……预期的那样。引用:我的字符串大概是这样的:任务:\n\n1亿2千匹 最佳答案 我found这段代码,我正要尝试一下。std::stringutf8_substr(conststd::string&str,unsignedintstart,unsignedintleng){if(leng==0){return"";}unsignedintc,i,ix,q,min=std::string::npos,max=std::s

c++ - 我可以将 final 关键字应用于 C++11 中的 POD(标准布局)结构吗?我是不是该?

在一个充满对象(具有适当行为)和相对较少的非面向对象结构(仅由数据字段和无方法组成)的C++项目中,我想防止意外误用这些结构,其中可能会尝试创建一个继承自它的类。根据我的理解,因为这些“POD”(普通旧数据)结构没有虚拟析构函数,所以不可能通过指针正确删除派生类对象(如果允许创建它)POD类型。这似乎是C++11“final”关键字的一个很好的用例,它将一个类或结构标记为不可继承。但是,我想知道“final”关键字是否会导致结构变为非POD?我怀疑标准文档可能已经解决了这个问题,但我不够聪明,无法在很长的文档中进行筛选以找出答案。欢迎任何有用的指示。注意:我对仅仅知道它通过了某些编译器

C++为什么有类头却有 "Unknown Type"?

这个问题在这里已经有了答案:Resolvebuilderrorsduetocirculardependencyamongstclasses(12个答案)关闭6年前。我有这个头文件,我正在尝试创建Item类型的变量。我已经包含了#include"Item.h",但在编译时我仍然在两个私有(private)变量上遇到unknowntypenameItem错误。#ifndefPLAYER_H#definePLAYER_H#include#include"Item.h"usingstd::vector;classPlayer{public://constructorPlayer(void);/

c++ - asio 1.11.0 独立包装不正确......还是我?

给定以下测试程序:#include#includeintmain(){asio::io_serviceios1,ios2;asio::io_service::strands2(ios2);autotest_func=wrap(s2,[&]{assert(s2.running_in_this_thread());});autowrap_test_func=wrap(ios1,test_func);wrap_test_func();ios1.run_one();ios2.run_one();}我的理解是这个程序不应该断言。wrap_test_func被包装到io_serviceios1中。

c++ - 在 C++11 中获取当前时间的最快方法是什么?

上下文:我正在编写一个高性能C++11应用程序,其中一部分是删除不活动的连接。为此,我在我的连接对象中存储了一个“上次事件”时间戳,我会在执行操作时更新它。然后我有一个每隔几秒运行一次的计时器,循环遍历所有session,并删除不活动的session。目前我正在使用这段代码来获取当前时间戳:timestamp=duration_cast(system_clock::now().time_since_epoch()).count()我想知道是否有更快的方法来做到这一点?我所说的更快是指获取时间戳本身的性能,而不是时间戳的分辨率。分辨率对于我的特定应用来说并不是很重要,它可以低至一秒。此外

c++ - 什么时候应该使用 const_iterator 而不是 auto

下面是一个例子,我认为它说明了使用const_iterator比使用“constauto”更可取的情况。这是因为容器不提供cfind()函数。还有其他选择吗?或者应该使用“constauto”而忽略const的缺失?std::stringGetJobTitle(conststd::string&employee){usingEmployeeTitles=std::unordered_map;EmployeeTitlesemployees={{"Alice","Director"},{"Bob","Manager"},{"Charlie","Developer"}};//Option1.

C++ 后递增 : objects vs primitive types

我们不能对右值使用预增量:inti=0;intj=++i++;//Compileerror:lvaluerequired如果我们定义一个类:classA{public:A&operator++(){return*this;}Aoperator++(int){Atemp(*this);returntemp;}};然后我们可以编译:Ai;Aj=++i++;A对象和int数据类型有什么区别j=++i++;用A编译而不用int编译? 最佳答案 发生这种情况是因为当重载运算符被定义为成员函数时,它们遵循一些与调用成员函数更相关的语义,而不是内

C++ : has_trivial_X type traits

boost库,似乎是即将推出的C++0x标准,定义了各种类型特征模板,以区分具有平凡构造函数、复制构造函数、赋值或析构函数的对象与不具有平凡构造函数的对象。其最重要的用途之一是优化某些类型的算法,例如通过使用memcpy。但是,我不明白所有各种has_trivial_X模板之间真正的实际区别。C++标准只定义了我们在这里关注的两大类类型:POD和非POD。如果一个类型具有已定义的构造函数、复制构造函数、赋值运算符或析构函数,则该类型是非POD。换句话说,任何不是内置类型或内置类型的C结构的东西都不是POD。那么区分has_trivial_assign和has_trivial_const

界面前瞻:微软 Windows 11 将原生支持 sudo 命令

IT之家 2月1日消息,微软已经邀请部分WindowsInsider项目成员,在WindowsServer最新预览版中,测试原生的sudo命令,而该功能未来将装备在 Windows11 系统中。IT之家注:sudo命令的superuserdo,可以让普通用户在部分命令中,以超级用户的权限运行。简单来说,就是让非root的用户运行只有root才有权限执行的命令。Windows现有用户也可以使用Sudo命令行实用程序,不过需要安装Scoop或通过WindowsSubsystemforLinux(WSL)才能使用。根据曝光的WindowsServer预览版截图,用户可以打开设置应用,在系统的开发者选

深度解析C++11新规范:引领现代编程潮流的30大特性

C++11——是C++编程语言的一场变革。这个版本为C++注入了一系列现代化的特性,使得编写高效、安全、可读性强的代码成为可能。让我们一同探索C++11带来的30大新规,为你揭示现代C++编程的无限可能性。1、自动类型推断(auto)C++11引入了auto关键字,通过它,编译器可以自动推断变量的类型,使得声明变量更加简洁。Copycodeautox=42;//x被推断为int类型2、范围-basedfor循环引入了范围-basedfor循环,遍历容器元素更加简洁、直观。Copycodefor(constauto&element:container){//对容器中的每个元素执行操作}3、智能指